<template>
  <div>
    <input :value="modelValue" class="el-input--inner" @input="onInput" />
  </div>
</template>

<script setup lang="ts">
import { emitter } from "../../emitter";

defineProps<{
  modelValue: string;
}>();

const emit = defineEmits<{
  // eslint-disable-next-line no-unused-vars
  (e: "update:model-value", value: string): void;
}>();

function onInput(e: Event) {
  const input = e.target as HTMLInputElement;
  emit("update:model-value", input.value);
  emitter.emit("validate");
}

defineOptions({ name: "ElInput" });
</script>

<style lang="scss">
@import "../styles/mixin";
@include b(input) {
  @include m(inner) {
    -webkit-appearance: none;
    background-color: #fff;
    background-image: none;
    border-radius: 4px;
    border: 1px solid #dcdfe6;
    box-sizing: border-box;
    color: #606266;
    display: inline-block;
    font-size: inherit;
    height: 40px;
    line-height: 40px;
    outline: 0;
    padding: 0 15px;
    transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
    width: 100%;
  }
}
</style>
